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This determination may be based on various factors such as the 
destination of the search results, the preferred status of certain 
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order based on the preferred status of certain records over other 
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SYSTEMS AND METHODS FOR ARRANGING RECORDS 
IN SEARCH RESULTS TO BE PROVIDED IN 
RESPONSE TO A DATA INQUIRY 

TECHNICAL FIELD 

This invention relates generally to systems and methods for 
the provision of information as search results in response to a data 
inquiry. More particularly, this invention relates to systems and methods 
for arranging the records of search results into ordered records to be 
included in the search results provided in response to a data inquiry of a 
database. 

BACKGROUND 

Let's change the rules of baseball. Let's provide that the 
players on each of the teams must be played at random. In other words, 
let's eliminate a baseball manager's right to decide the line-up of his or 
her team. 

What general effect would this rule change have on a game? 
It would turn baseball even further from a game of strategy and tactics to 
a game of chance. What effect would this rule change have on the 
manager? By eliminating the manager's right to decide the line-up of his 
or her team, the manager is robbed of one category of his or her tactical 
inputs into the game. The manager becomes even less of a master or 
mistress with respect to the outcome of the game. What effect would this 
rule change have on the team owner? By eliminating the manager's right 
to decide the line-up of his or her team, the team owner does not have to 
consider the manager's skill in setting a line-up when hiring or firing a 
manager. But like the manager, the team owner is faced with even less 
certainty of a winning ball club. What effect would this rule change have 
on the baseball fan? By eliminating the manager's right to decide the 
line-up of his or her team, the fan does not know who is coming to the 
plate until the last minute. At times, a particular player's appearance at 
the plate may be a pleasant, welcome and hoped for surprise. But at 
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others, another player's appearance at the plate may foreshadow an 
unhappy result in the ballgame. Like the manager and the team owner, 
under this new rule, the baseball fan arrives at the ball park with a lot 
less certainty regarding the pending outcome of the ballgame. 

5 Our disturbance of the rules of baseball is sure to have left 

many readers uncomfortable. Like the baseball manager, we like to set 
the line-up of our team. Many of us prefer to have tactical and strategic 
input into events that take place in our lives. By this input, we may 
control or at least have some control of these events so as to maximize 

10 the advantages. For example, we may arrange the tasks of our workday 
so as to more efficiently or economically derive advantages from the 
workday. But in many areas, the line-up is not set and information or 
other occurrences are thrown at us at random. 

An area in which information is often provided at random to 

15 the user is in the area of information retrieval. For example, assume that 
a user is using a computer system to search a database for certain 
information. The user formulates a data inquiry and transmits it to the 
system. After the system conducts the search of the database, the 
information that was found during the search is provided as search 

20 results to the user in response to the data inquiry. Typically, search 
results include more than one piece of information which we refer to 
herein as a record. Thus, the user is typically provided with more than 
one record in the search results. 

Generally, the records in search results are provided in 

25 random order to the user. This oxymoron, "random order", denotes that 
each record is provided to the user without regard to the other records in 
the search results. Further, random order also may denote that each 
record is provided to the user without regard to factors that may relate 
to the user, the data inquiry, the database, the other records in the search 

30 results as well as without regard to other factors. In some cases, the 
records of search results may be provided in an alphabetical order, 
which is considered generally to be a sub-set of random order. 
Alphabetical order is considered to be such a sub-set of random order 
because alphabetical order is generally not based on some relationship 

35 factor linking the records. Rather, alphabetical order or an alphabetical 
relationship amongst the records is based on the happenstance of use of a 
term and a particular letter of the alphabet associated with that term. 
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The term(s) used to alphabetize the records in the search results may be 
arbitrarily and randomly chosen. Thus, the term "random order" is used 
herein to include alphabetical order of records in search results. To 
return to our baseball analogy, when the records of search results are 

5 provided in random order, it is like playing the members of a baseball 
team at random. This random order may include playing the members 
of the baseball team in alphabetical order based on their first names, last 
names, nicknames, hometowns, etc. 

As noted, the records in search results may be provided in 

10 random order by the service provider of the search results. In the event 
of such provision of records in random order, the search provider is like 
the baseball manager under the new rules of baseball. The search 
provider loses tactical and strategic input into the "game" of providing 
search results. The service provider lacks control that otherwise could 

15 be used to provide search results in some advantageous tactical or 
strategic manner. 

This lack of control may affect the service provider's ability 
to retain or attract clients. A client is distinguished herein from a user* 
A client of a service provider generally is defined herein to be an entity 

20 that supplies the service provider with information that may be used in 
the service provider's database. A client may pay or otherwise 
remunerate the service provider to use the client's information in the 
database, and in particular, in the search results that are provided to 
users making database inquiries. For example, the service provider may 

25 maintain and provide search results from a database such as a classified 
advertising database. In this example, a client may be an entity that 
provides information for use in the classified advertising database such as 
an advertisement. This advertisement may become a record in the 
classified advertising database. 

30 If the service provider lacks control with respect to the 

order of records in search results, then the client's information may not 
make its way into advantageous positions in the search results. 
Alternatively, the client's information may not make its way often 
enough to the client's satisfaction into advantageous positions in the 

35 search results provided to users by the service provider. The client then 
is less certain with such a service provider that the client's information 
will make it into a good position in the "line-up" of records in the search 
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results. In a sense, the client may be likened to the team owner (of 
information) in our baseball analogy. The client as the team owner may 
be very interested in the talents of the service provider as the manager in 
setting the line-up of records of the search results. If the service 

5 provider does not have any such talents, or if they are very limited, then 
the client as the team manager is less certain of a winning line-up that 
includes the client's information being provided to users. Similarly, if 
we refer to the classified advertising database example, if the service 
provider lacks control with respect to the order of advertisements that 

10 are provided in search results to a user, then the advertiser's information 
may not make its way into advantageous positions in the search results. 
Or, the advertiser's information may not make its way often enough to 
the advertiser's satisfaction into advantageous position in the search 
results. The advertiser then may be less willing to advertise with the 

15 service provider of the classified advertising directory, or at least be less 
willing to pay premiums for such advertising services. 

The lack of control in providing search results also may 
affect the service provider's ability to retain or attract users. As noted 
above, a user is distinguished herein from a client. A user of a service 

20 provider generally is defined herein to be the person or entity that makes 
a data inquiry for information of the service provider. Like a client, the 
user may pay or otherwise remunerate the service provider. But in the 
case of the user, the remuneration typically is for the service of 
providing information to the user in the form of records in search results 

25 in response to a data inquiry. If the service provider lacks control with 
respect to the order of records in search results, then the information 
may be provided to the user in an order that is difficult to use. The user 
is not provided with a good "line-up" of records in the search results. In 
a sense, the user may be likened to the fan in our baseball analogy. The 

30 user as the fan may be very interested in the talents of the service 
provider as the manager in setting the line-up of records of the search 
results. If the service provider does not have any such talents, or if they 
are very limited, then the user as a fan is less certain of a winning line-up 
of records in the search results. If the service provider cannot set a line- 

35 up of records in search results, then the user as the fan does not know 
who or what is coming to the plate until the record arrives. At times, a 
particular record's appearance at the plate may be a pleasant, welcome 
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and hoped for surprise. Or, like in the baseball analogy, another 
record's appearance may foreshadow an unhappy or unusable result. 
Like the service provider as the manager and the client as the team 
owner, when there is random order to records in search results, then the 

5 user as the baseball fan has a lot less certainty regarding the outcome in a 
ballgame of information retrieval. 

In conclusion, there is a need in the field of information 
retrieval to provide the records in search results other than in random 
order so as to retain advantageous tactical and strategic input with respect 

10 to the provision of such search results in response to data inquiries, 

SUMMARY 

Generally stated, the present invention provides several 
different systems and methods for arranging records in search results 

15 into ordered records to be included in the search results provided in 
response to a data inquiry of a database. Advantageously, the records in 
search results are arranged into ordered records so that the service 
provider may retain tactical and strategic input with respect to the 
provision of such search results in response to data inquiries. By this 

20 invention, the service provider may benefit by being able to provide 
additional services or features with respect to information retrieval. 
These additional services or features may afford the service provider 
with competitive advantages over other service providers of information. 
In particular, these additional services or features may serve to retain or 

25 attract clients as well as users to the service provider. 

Further, these additional services or features may be 
especially attractive to clients and users for several reasons. A service 
that provides ordered records in search results may be attractive to a 
client because the client may benefit by having its information appear as 

30 records more often or more advantageously positioned in the search 
results that are provided to users. The client may take advantage of one 
or more of the several different systems and methods for ordered 
records in search results so that the client's information is used or placed 
for maximum effect with respect to users. In addition, a service that 

35 provides ordered records in search results may be attractive to a user 
because the user may benefit by having records delivered in search 
results in a more usable or otherwise more advantageous manner. 
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Stated generally, the present invention provides several 
different systems and methods for arranging records in search results to 
be provided in response to a data inquiry of a database. After search 
results including records are received, a determination is made with 
5 respect to the order of the records in the search results. This 
determination may be based on one or a combination of factors such as 
on the destination of the search results, on the preferred status of certain 
records over other records, on a marketing determination with respect to 
the records, on a frequency determination with respect to the number of 

10 times that a record or records may have already been provided in 
response to data inquiries, or on a weighting factor determination. In 
response to the determination of the order of the records in the search 
results, the records then are arranged into ordered records based on the 
determination. The order of these ordered records may be an 

15 alphabetical order, a preferred order based on the preferred status of 
certain records over other records, a least frequent first (LFF) order, or 
a highest weighting factor first (HWFF) order or a combination of these 
orders. The search results with the records arranged as ordered records 
are then provided in response to the data inquiry. 

20 Stated less generally, the present invention provides a system 

and a method for arranging records in search results with the 
arrangement being based on the destination of the search results. 
Pursuant to the exemplary system and method, a destination 
determination is made for the search results. In response to the 

25 destination determination, the records of the search results are arranged 
into a destination order based on the destination determination. The 
destination order may be an alphabetical order. Alternatively, the 
destination order may be a preferred order of listing a preferred record 
before other records in the search results. The search results in the 

30 destination order are then provided in response to the data inquiry of the 
database. As another alternative, the destination order may be a least 
frequent first (LFF) order. The LFF order provides that a least frequent 
(LF) record is listed before other records in the search results. The LF 
record is a record of the search results that has been included in other 

35 search results less often than any other record of the search results. In 
response to the destination determination, a determination then is made 
of the LF record of the search results. The records of the search results 
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then are arranged into the LFF order in the search results. The records 
of the search results in the LFF order are then provided in response to 
the data inquiry of the database. As yet another alternative, the 
destination order may be a weighting factor determination then is made 

5 as to whether the records of the search results are to be provided in a 
highest weighting factor first (HWFF) order. The HWFF order provides 
that a highest weighting factor (HWF) record is listed before other 
records in the search results. The HWF record may be a record of the 
search results that has a higher weighting factor than any other record of 

10 the search results. In response to the weighting factor determination, a 
determination is made of the HWF record of the search results. The 
records of the search results then are arranged into the HWFF order, the 
records in the HWFF order are provided in response to the data inquiry 
of the database. 

15 Stated more particularly, the present invention provides a 

system and a method for arranging records in search results with the 
arrangement being based on a marketing determination with respect to 
the search results or other factors. Pursuant to the exemplary system and 
method, a marketing determination is made with respect to the order of 

20 the records in the search results. This marketing determination may be 
that the records be listed in a preferred order with a preferred record 
being listed before other records in the search results. In response to the 
marketing determination, a determination is made as to whether a record 
of the search results is a preferred record. If so, then the records of the 

25 search results are arranged into the preferred order in the search results. 
The search results in the preferred order are then provided in response 
to the data inquiry of the database. 

Also, stated more particularly, the present invention 
provides a computer-readable medium on which is stored a computer 

30 program for arranging records in search results to be provided in 
response to a data inquiry of a database. The computer program includes 
instructions, which when executed by a computer, perform the steps of 
receiving search results including records and making a determination 
regarding an order of the records in the search results. The 

35 determination may be based on at least one of the following: the 
destination of the search results, the preferred status of certain records 
over other records, a marketing determination with respect to the 
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records, a frequency determination with respect to the number of times 
that a record may have already been provided in response to data 
inquiries, or a weighting factor. In response to the determination, the 
instructions perform the step of arranging the records of the search 

5 results as ordered records. The ordered records may be the records 
arranged into at least one of the following: an alphabetical order, a 
preferred order based on the preferred status of a record over the other 
records, a least frequent first order, or a highest weighting factor first 
order. Finally, the instructions then perform the step of providing the 

10 search results including the ordered records in response to the data 
inquiry of the database. 

In conclusion, it is an object of the present invention with 
respect to the field of information retrieval to provide systems and 
methods for arranging the records of search results into ordered records 

15 to be included in the search results in response to a data inquiry of a 
database. 

It is also an object of the present invention to provide 
systems and methods for arranging the records of search results into 
ordered records based on characteristics or factors associated with the 

20 destination of the search results, on the records of the search results, on 
the clients or entities supplying the information, on the clients or entities 
receiving the search results, and on other characteristics and factors. 

It is a further object of the present invention to provide 
records in search results other than in random order so as to retain 

25 advantageous tactical and strategic input with respect to the provision of 
such search results in response to data inquiries. 

The exemplary systems, methods and embodiments of the 
present invention are described herein in the context of arranging 
records in search results obtained from a database such as a database of 

30 classified advertising information. Nonetheless, the present invention 
may be applied to a broad variety of other systems and methods, and in 
particular, may be applied to a broad variety of other information 
retrieval systems, search engines, and databases. 

The present invention and its objects and advantages, those 

35 described above and otherwise, may be further appreciated from a 
review of the following detailed description, drawings and claims. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram of a computer system that provides 
an exemplary operating environment for embodiments of the present 
invention. 

5 Fig. 2 is a block diagram of a distributed computer system 

that provides an exemplary operating environment for an embodiment of 
the present invention. 

Fig. 3 is a diagram illustrating software components and 
their operative interrelationships in the exemplary embodiments of the 
10 present invention. 

Fig. 4 is a flow diagram illustrating steps of an exemplary 
method of the present invention. 

Fig. 5, consisting of Figs. 5 A - 5D, illustrate alternative 
steps of exemplary methods of the present invention. 

15 

DETAILED DESCRIPTION 
Introduction 

This detailed description provides information with regard 

20 to several different exemplary systems and methods for arranging 
records in search results into ordered records to be provided in response 
to a data inquiry of a database. The exemplary embodiments and 
methods described herein are intended in all respects to be illustrative 
rather than restrictive. Alternative embodiments and methods will be 

25 apparent to those skilled in the art. The present invention is described in 
this detailed description first by a general description of exemplary 
systems and methods of the present invention and then by a general 
description of the types of computer systems and software modules that 
may embody or be used in connection with the present invention. 

30 Following these general descriptions, a more detailed 

description of a stand-alone computer system as an exemplary operating 
environment is provided in connection with Fig. 1 . Then a more detailed 
description of a distributed computer system as an exemplary operating 
environment is provided in connection with Fig. 2. After the 

35 descriptions of these computer systems, a description of illustrative 
software components and their operative interrelationships in the 
exemplary embodiments is presented in connection with Fig. 3. A flow 
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diagram illustrating steps of an exemplary method of the present 
invention is described in connection with Fig. 4. Finally, in Fig, 5, 
alternative steps of exemplary methods of the present invention are 
described. 

5 

A General Description of Exemplary Systems and Methods of the Present 
Invention 

Stated generally, the present invention provides methods for 
arranging records in search results to be provided in response to a data 

10 inquiry of a database. After search results including records are 
received, a determination is made with respect to the order of the 
records in the search results. This determination may be based on one or 
a combination of factors such as on the destination of the search results, 
on the preferred status of certain records over other records, on a 

15 marketing determination with respect to the records, on a frequency 
determination with respect to the number of times that a record or 
records may have already been provided in response to data inquiries, or 
on a weighting factor determination. In response to the determination of 
the order of the records in the search results, the records then are 

20 arranged into ordered records based on the determination. The order of 
these ordered records may be an alphabetical order, a preferred order 
based on the preferred status of certain records over other records, a 
least frequent first order, or a highest weighting factor first order or a 
combination of these orders. The search results with the records 

25 arranged as ordered records are then provided in response to the data 
inquiry. 

A General Description of the Types of Computer Systems and Program 
Modules that Mav Embody or Be Used in Connection with the Present 
30 Invention. 

The preferred embodiment of the present invention is 
embodied as part of a group of program modules that operate as an 
interactive information retrieval system (hereinafter the "IR system") 
used with a multi-tasking computer or computer system. Generally, 
35 program modules include routines, programs, records, data structures, 
steps, etc. that perform particular tasks or implement particular abstract 
data types. The present invention also may be implemented in 
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conjunction with objects and other program modules for other types of 
computers or computer systems. 

The present invention may be embodied within or carried 
out by a stand-alone computer or computer system or a distributed 

5 computer system. In a distributed computing environment, program 
modules may be physically located in different local or remote memory 
storage devices. Execution of the program modules may occur locally in 
a stand-alone manner or remotely in a client/server manner. Examples of 
such distributed computing environments include local area networks, 

10 enterprise- wide computer networks, and the global Internet. Examples 
of such computer environments are provided in the following 
commonly-assigned patent applications: A System and Methods for 
Dynamically Processing an Index to Dynamically Create a Set of 
Questions, Serial No. 08/844,751, filed on April 21, 1997, (Attorney 

15 Docket No. 19260-0960), and A System and Methods for Routing 
Information within an Adaptive Routing Architecture of an Information 
Retrieval System, Serial No. 08/866,228, filed on May 30, 1997, 
(Attorney Docket No. 19260-1000). Both of these referenced patent 
applications are incorporated herein by reference. The present invention 

20 also may be practiced with other system configurations, including hand- 
held devices, multiprocessor systems, microprocessor-based or 
programmable consumer electronics, minicomputers, mainframe 
computers, and the like. Other methods and system implementations will 
occur to those skilled in the art. 

25 As noted, the preferred embodiment of the present invention 

is embodied as part of a group of program modules that operate as an 
interactive 1R system. Briefly described, the IR system allows a user (via 
voice or digital communication signals) to make a request for 
information. This request for information is referred to herein as a data 

30 inquiry, or also as a search request or search query. The information 
may be stored in one or more databases associated with the IR system. 
Based upon the data inquiry, the IR system may obtain search results, 
which also may be referred to as a set of search results. These search 
results may be considered to be the information that is obtained during 

35 the search of the relevant databases. Typically, a set of search results 
includes one or more records. Each record may be considered to be an 
answer to the data inquiry. 
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The description of the present invention is presented in 
terms of systems, methods, processes and symbolic representations of 
operations by conventional computer elements such as a processor, 
memory storage devices, data communications networks, and 
5 communication interfaces such as telephone line cards or network 
interface cards. These systems, methods, processes and symbolic 
representations of operations may include the manipulation of signals by 
a processor and the maintenance of these signals within data sets and data 
structures. These data sets and data structures are resident in one or 

10 more memory storage devices. A data set is commonly understood to be 
collection of related information that may exist as separate elements, but 
that may be manipulated as a unit. A data structure is commonly 
understood to be an organizational scheme that encapsulates data in order 
to support data interpretations and data operations. The data structure 

15 imposes an organization upon the collection of data stored within a 
memory storage device and represents specific electrical or magnetic 
elements. A data structure may be created from the separate elements 
or objects of a data set or another data structure. A database may be a 
data set or a data structure depending on the particular implementation. 

20 These symbolic representations are used by those skilled in the art of 
computer programming and computer construction to convey teachings 
and discoveries to others skilled in the art. 

A process is generally considered to be a sequence of 
computer-executed steps leading to a desired result. These steps may 

25 require physical manipulations of physical quantities. Commonly, these 
quantities take the form of electrical, magnetic, or optical signals that 
may be stored, transferred, combined, or otherwise manipulated. These 
representations of signals are generally referred to as bits, bytes, words, 
information, an index, terms, index categories, domains, data, objects, 

30 records, images, files or the like. These and similar terms are associated 
with appropriate physical quantities for computer operations, and are 
applied as conventional labels to physical quantities that exist within and 
during operation of the computer or computer system. 

Manipulations with respect to the computer or computer 

35 system are often referenced with terms such as providing, arranging, 
searching, transmitting, receiving, prompting, determining, identifying, 
storing, selecting, deleting, etc. These terms are often associated with the 
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manual operations that may be performed by a user in carrying out these 
manipulations with the computer or computer system. But these 
manipulations are machine operations performed in conjunction with 
various inputs provided by the user that interacts with the computer, 

5 computer system or other device. 

The systems, methods, processes, symbolic representations, 
processes and the like that are described herein are unrelated to and not 
limited to particular computers, computer systems, elements thereof, 
networks, or computer or communication architectures* To the 

10 contrary, various types of general purpose machines may be used with 
program modules, programs or steps constructed in accordance with the 
teachings described herein. It may be advantageous to devote a 
specialized apparatus to perform the steps described herein by way of 
dedicated computer systems in a specific network architecture with hard- 

15 wired logic or programs stored in nonvolatile memory, such as read only 
memory (ROM). 

Exemplary Operating Environment - Stand-alone Computer System - 
Fig. 1 

20 Referring now to Fig. 1, an exemplary stand-alone computer 

system for implementing the present invention includes a conventional 
stand-alone computer 20, including a processor 21, a system memory 22, 
and a system bus 23 that couples the system memory 22 to the processor 
21. The system memory 22 includes random access memory (RAM) 25. 
25 The stand-alone computer 20 further includes a hard disk drive 27 and 
an optical disk drive 30 (e.g., a disk drive that reads from a CD-ROM 
disk 31 or reads from or writes to other optical media). The hard disk 
drive 27 and the optical disk drive 30 are connected to the system bus 23. 
The drives and their associated computer-readable media provide non- 
30 volatile storage for the stand-alone computer 20. Although the 
description of computer-readable media above includes the hard disk 
drive 27 and the optical disk 31, such as a CD, other types of media 
which are readable by a computer, such as removable magnetic disks, 
magnetic cassettes, flash memory cards, digital video disks and tapes, 
35 Bernoulli cartridges, and the like, may also be used in each of the 
exemplary operating environments described with regard to Fig. 1 and 
Fig. 2. 
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A number of program modules may be stored in the drives 
27, 30 and RAM 25, including an operating system 32 and a variety of 
other software program modules. In an embodiment of the present 
invention, an example of such software modules is a group of software 
modules collectively referred to as the interactive information retrieval 
system modules 26 (JR system modules). The IR system modules 26 
preferably include the following software modules: 

• one or more frontend modules 33, 

• a recognizer module 34, 

• a dialoger module 35 (which interacts with script files 36 
and an index 37 and dispatches search requests to the 
search engine 39), 

• a middleware layer of software 38 including a 
randomization module 100, and 

9 a 2>caiuii engine jy ^vvniuii miciaCLS wiui a uaiaua^ *+v; 

stored on the hard disk drive 27 or on the optical disk 31 
in the optical disk drive 30). 

When any of the IR system modules 26 are used, the 
processor 21 may bring only a portion of the module into memory at a 
time due to the size of the module. 

The operating system 32 provides the basic interface 
between the computer's hardware and software resources, the user, and 
the IR system modules 26. In the exemplary operating environments 
described with regard to Figs. 1 and 2, the operating system 32 is 
preferably a real-time operating system, such as the SOLARIS operating 
system, produced by SunSoft, a division of Sun Microsystems. A real- 
time operating system is preferred in order to provide adequate response 
when searching and interacting with multiple users. The SOLARIS 
operating system has a multithreaded, symmetric multiprocessing, real- 
time UNIX kernel. Those skilled in the art will appreciate the need for 
real-time, multithreaded performance in information retrieval 
applications in order to support an adequate level of transactional 
performance. Additional information regarding the SOLARIS operating 
system is available by reference to system manuals published by Sun 
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Microsystems and other widely available literature on UNIX operating 
systems. 

As with most conventional computer systems, a user may 
enter commands and information into the stand-alone computer 20 

5 through a keyboard (not shown) and an input or pointing device, such as 
a mouse (not shown). Other input devices (not shown) may include a 
microphone, a joystick, a game pad, a satellite dish, a scanner, or the 
like. These and other input devices are often connected to the processor 
21 through a serial port interface (not shown), such as a game port or a 

10 universal serial bus (USB), connected to the system bus 23. A monitor 
(not shown) or other type of display device can also be connected to the 
system bus 23. In addition to the monitor, computers such as the stand- 
alone computer 20 typically include other peripheral output devices (not 
shown), such as speakers, printers, and backup devices. 

15 In the preferred embodiment, a user typically interacts with 

the stand-alone computer 20 when the stand-alone computer 20 functions 
in a server capacity. In this capacity, the stand-alone computer 20 can 
service a remote programmable device, such as a remote computer 41, 
or a telephone device, such as a conventional telephone 42, each of which 

20 is logically connected to the stand-alone computer 20. 

The remote computer 41 may be a server, a router, a peer 
device, or other common network node. Typically, the remote computer 
41 includes many or all of the elements described relative to the stand- 
alone computer 20. The logical connection between the remote computer 

25 41 and the stand-alone computer 20 depicted in Fig* 1 is a data 
communications network, such as a wide area network (WAN) 43. 
Other examples of data communications networks include enterprise- 
wide computer networks, intranets, or the global Internet. A 
communications interface, such as a network communications interface 

30 44 in the stand-alone computer 20, links the WAN 43 and the stand-alone 
computer 20. However, the logical connections to the stand-alone 
computer 20 may also be a local area network (LAN) (not shown) that is 
commonplace in offices. Typically, a user of the remote computer 41 
interacts with the stand-alone computer 20 via such logical connections in 

35 order to search the database 40 for information and to respond to 
scripted questions posed by the stand-alone computer 20. 
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The exemplary database 40 contains a plurality of records 
(not illustrated). Each record contains specific information. By way of 
explanation, reference is made to a database that includes records of 
classified advertising information. An example of the type of specific 

5 information that may be stored in the record of such a database is 
information about a restaurant. This restaurant information in a record 
may include the kind of cuisine served by the restaurant, the location of 
the restaurant, the hours of the restaurant's operation, payments methods 
accepted by the restaurant, and any offered amenities. The database 40 

10 may include flat-file records, but the database also may include or be a 
data structure including records that may be relational tables. Further, 
each record may include one or more fields or tables. 

A telephony communication interface 45 (also known as a 
telephony line card) connected to a conventional public switched 

15 telephone network 46 (PSTN) provides the logical connection between 
the stand-alone computer 20 and the conventional telephone 42. In this 
manner, the user may interact with the stand-alone computer 20 with 
voice responses via a conventional telephone 42 or other telephonic 
device. In the preferred embodiment, the telephony communication 

20 interface 45 is a Model Antares 2000 telephone line interface card 
manufactured by Dialogic Corporation of Parsippany, New Jersey. 
Both the network communications interface 44 and the telephony 
communication interface 45 are generally referred to as "communication 
interfaces " because the stand-alone computer 20 provides the service of 

25 processing data inquiries through both of these interfaces. The network 
and telephone connections shown are exemplary and other means of 
establishing a communications link between the stand-alone computer 20 
and the remote computer 41 or conventional telephone 42 may be used. 

30 Exemplary Operating Environment - Distributed Computer System - 
Fig. 2 

In Fig. 2, a block diagram of a distributed computer system 
is illustrated that also provides an exemplary operating environment for 
an embodiment of the present invention. Referring now to Figs. 1 and 2, 
35 the distributed computer system 200 includes a backend server 201 and 
one or more front end servers, such as an Internet frontend server 202 
or a telephony front end server 203. 
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In this distributed computing environment, the functions 
performed by the stand-alone computer 20 can be broken apart and 
allocated amongst each of the servers 201-203. In this manner, resources 
can be dedicated in order to more efficiently interact with users and 

5 search the database (via the Internet front end server 202 and the 
telephony front end server 203) and to centralize file storage and 
maintenance of certain data files (via the backend server 201). The 
ability to break apart and allocate the functions amongst different servers 
is advantageous because users can rely on dedicated hardware and 

10 software for enhanced transactional processing. 

Furthermore, the manner of providing the database 40, the 
index 37, and the script files 36 is simplified by providing access to these 
software modules from a central location. Only the software modules in 
the central location need be updated. From the central location, each 

15 frontend server 202-203 can then access and copy the most up-to-date 
software modules used when processing data inquiries. Thus, centrally 
maintaining these files is preferred over individually updating these 
software modules in each server 202-203. 

The backend server 201 is similar to the stand-alone 

20 computer 20 from a hardware perspective. The backend server 201 has 
a system memory 204 and memory storage devices (such as the hard disk 
drive 27 and the optical disk drive 30) which are used to maintain the 
database 40, the index 37, and the script files 36. By maintaining the 
database 40, the index 37, and the script files 36 in this central location, 

25 they are easier to consistently maintain and update. The backend server 
201 provides each of the frontend servers 202-203 access to these files 
over a conventional data network 205 (LAN, WAN, etc.) that 
electronically connects the backend server 201 to the frontend servers 
202-203. The backend server 201 is preferably a file server for 

30 centrally maintaining and updating these files. But it is contemplated that 
the backend server system memory 204 may also include the JR system 
modules 26 in order to operate similarly to the stand-alone computer 20. 
In this manner, the backend server 201 may function as a peak-time 
frontend server when needed to assist one of the frontend computers 

35 202-203. 

Each of the frontend servers are similar to the stand-alone 
computer 20 from a hardware perspective and from a software 
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perspective. The Internet frontend server 202 preferably includes each 
feature of the stand-alone computer 20, but does not need any telephony 
communication interfaces 45. The network communication interface 44 
on the Internet frontend server 202 is used to communicate with the 
5 backend server 201. The telephony frontend server 203 essentially has 
the same elements as the stand-alone computer 20. Similar to the 
Internet frontend server 202, the network communication interface 44 on 
the telephony frontend server 203 is used to communicate with the 
backend server 201. 

10 Essentially, the frontend servers 202-203 interact with users 

and process user's requests for information. In one situation, the remote 
computer 41 is configured as a remote device manipulated by the user 
via data entry. The remote computer 41 interacts with the Internet 
frontend server 202 via the WAN 43 and a service communication 

15 interface (preferably similar to the network communication interface 44) 
within the Internet frontend server 202. In this situation, the remote 
computer 41 preferably communicates with the Internet frontend server 
202 using a conventional hypertext transfer protocol (HTTP). Thus, the 
Internet frontend server 202 preferably functions as a Web server 

20 providing the remote computer 41 with access to information within the 
database 40. 

In another situation, a conventional telephone 42 or other 
telephonic device is the remote device manipulated by the user via voice 
input The telephone 42 interacts with the telephony frontend server 202 

25 via the PSTN 46 and a service communication interface (such as a 
telephony line card 45) within the telephony frontend server 203. Data 
inquiries from the user are processed locally by each frontend server 
202-203 in a timely manner using the copied files (i.e., the copied 
database 210, the copied index 21 1, and the copied script files 212) along 

30 with the IR system modules 26. 

Each frontend server 202-203 accesses the backend server 
201 in order to make copies of the database 40, the index 37, and the 
script files 36 from the backend server 201. These copied files (i.e., the 
copied database 210, the copied index 211, and the copied script files 

35 21 2) are typically maintained by the frontend servers 202-203 within a 
memory storage device (not shown) within each frontend server. Each 
of the frontend servers 202-203 have system memory 206-207 and 
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memory storage devices (not shown) which are used to maintain the 
copied files and the IR system modules 26. In this manner, each frontend 
server 202-203 has local access to these copied files and avoids 
unnecessary traffic across the data network 205 when individually 
5 processing data inquiries from users interacting with the frontend servers 
202-203. Thus, the frontend servers 202-203 can focus their operation 
on serving users by utilizing the copied files (i.e., the copied database 
210, the copied index 211, and the copied script files 212) along with the 
IR system modules 26. 

10 As discussed earlier, the preferred embodiment of the 

present invention is embodied in the IR system modules 26 which are 
designed to operate in stand-alone and distributed computing systems in 
conjunction with SunSoft's SOLARIS operating system. However, it 
should be understood that the invention can be implemented for use with 

15 other computer architectures, such as multiprocessing systems. 
Furthermore, it should be understood that the invention can be 
implemented for use with other operating systems, such as Microsoft 
Corporation's "WINDOWS NT" operating system, IBM Coiporation's 
AIX operating system, and Hewlett-Packard's HP-UX operating system 

20 or RT-UX operating system. 

From this brief description, it should be appreciated that 
operating systems, such as the "SOLARIS" operating system, and 
networking architectures are quite complex and provide a wide variety 
of services that allow users and programs to utilize the resources 

25 available in the computer or in other computers in a distributed 
computing environment. Those skilled in the art will be familiar with 
operating systems, networking architectures and their various features. 
Likewise, those skilled in the art will appreciate that the IR system 
modules 26 provide a wide variety of features and functions in addition 

30 to those included in the brief description presented above. Exemplary IR 
system modules are described below. 

Program Modules within the Exemplary IR System -Fig. 3 

Fig. 3 is a diagram illustrating the IR system modules 26 and 
35 their operative interrelationships in the exemplary embodiments of the 
present invention. Generally, the IR system modules 26 are used to 
process a data inquiry. More particularly, a data inquiry may be 
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received through one of the front end modules 33 of the IR system 
modules 26. These front end modules 33 may include an interactive 
voice response (IVR) 205, a recognizer module 210, a data front end 
215, or other front end module as appropriate. At the appropriate front 

5 end module 33, the data inquiry may receive some formatting or other 
processing prior to being further transmitted to the IR system module 
referred to as the middleware routing architecture (MRA) 38. The MRA 
38 is used to process a data inquiry by adaptively routing the data inquiry 
from one of the front end modules 33 to the search engine module 39. 

10 As illustrated in Fig. 3, the MRA 38 includes a variety of interactive 
software modules including a router library 240, a router engine 230, a 
registration table 235, and an exemplary module queue 245. Each of 
these modules provides connecting or routing services within the IR 
system 26. The MRA 38 also contains a randomization module 100 as is 

15 explained in further detail below. 

As noted above, the MRA 38 is used to process a data 
inquiry by routing the data inquiry to the search engine module 39, 
which in turn provides the data inquiry to the search engine for a search 
of the records of the database. After the database has been searched, the 

20 search results are returned from the search engine module 39 to the 
MRA 38 wherein processing of the search results may take place as is 
described below. This processing may include the arrangement of the 
records of the search results into ordered records. After this processing 
of the search results takes place, the search results are generally 

25 transmitted from the MRA 38 to the delivery modules 34 of the IR 
system modules 26. These delivery modules may include a text-to-speech 
(TTS) module 220, a fax module 225, or other delivery module. 

Randomization Module 

30 As noted, after the search results are returned from the 

search engine module 39, the search results are received in the MRA 38, 
wherein the records in the search results may be arranged into ordered 
records. Of course, the search results do not have to be arranged into 
ordered records. This is a selectable feature and method that may be 

35 implemented based on a variety of factors. The processes carried out 
with respect to the arrangement of records into ordered records are 
generally carried out in the MRA 38 by the randomization module 100, 
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which is called as necessary or appropriate by the other modules of the 
MRA 38* Generally, upon receipt of search results in the MRA 38, the 
router engine 230 may check with or call the randomization module 100 
and/or the router library 240 for information or to handle the record 
5 arrangement processes. While the randomization module 100 may 
handle the arrangement processes, the router library 240 may be used by 
the randomization module 100 (and other modules) to check for 
information as to whether to arrange the records of any particular set of 
search results, and further, as to whether to arrange the records into a 

10 particular type of ordered records. Additional information regarding 
these processes is provided in progressively greater detail below. 

Pursuant to an exemplary embodiment, after receipt of the 
search results in the MRA 38, a determination as to whether to arrange 
the records of the search results into ordered records is made in the 

15 MRA 38. This determination is made through the exchange of 
information necessary for such a determination among the modules of 
the MRA 38, and in particular, the randomization module 100 and the 
router library 240. A further determination as to whether to arrange the 
records into a certain type of ordered records may be made in the MRA 

20 38 as a separate determination or as part of the above-mentioned 
determination as to whether to arrange the records into ordered records. 
The determination with respect to the type of ordered records also may 
be made through the aforementioned information exchange between the 
randomization module 100 and the router library 240, through an 

25 additional information exchange between these elements, or in any other 
manner as will be known to those skilled in the art. Additional details 
regarding these determinations and information exchanges are provided 
below in connection with the examples of the exemplary embodiments. 

Further, the determinations as to whether to arrange the 

30 records of the search results into ordered records and the type of 
ordered records for the arrangement may be based on a variety of 
selectable factors. These factors may include arrangement of records 
into ordered records based on: (1) an automatic response to the receipt 
of any search results that the records thereof be arranged into ordered 

35 records; (2) the destination of the search results such as the data frontend 
215; (3) an association of one or more of the records in the search results 
with a particular characteristic such as the association of a record with a 
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client or other entity; (4) a status of one or more of the records in the 
search results as a preferred record; (5) the frequency or number of 
times that a record or records have appeared in other search results; or 
(6) a weighting factor assigned to one or more of the records in the 

5 search results. 

The determinations as to whether to arrange the records of 
the search results into ordered records and the type of ordered records 
for the arrangement may be based any one of these aforementioned 
factors or on a combination of these factors as appropriate. In addition, 

10 these determinations may be different and based on different factors with 
respect to each set of search results received in the MRA 38. 

Further, the router library 240 may be provided with 
information so that the determinations with respect to a set of search 
results as to whether to arrange the records of the search results into 

15 ordered records and the type of ordered records for the arrangement 
may be carried out based on the selectable factors. Thus, the router 
library 240 may store, relate and provide information, as appropriate, 
with respect to records, search results, destinations, frequency scales, 
weighting factors or status, characteristics or factors of records, search 

20 results, clients or other entities. Additional details regarding these 
determinations and the factors for the basis thereof are provided below 
in connection with the examples of the exemplary embodiments (Figs. 
5A- 5D). 

25 Summary of Exemplary Method Steps - Fig. 4 

Fig. 4 is a flow diagram illustrating an exemplary method of 
the present invention for the arrangement of the records into ordered 
records in the search results. The method is entered at start step 400, 
and proceeds to step 402 wherein search results including records are 

30 received. As explained above, generally a set of search results is 
received in the MRA 38 after a search of a database 40 has been 
conducted. After the search results are received, then in step 404 a 
determination is made as to whether to order the records into ordered 
records. As also explained above, this determination is generally carried 

35 out in the MRA 38 through an exchange of information between the 
appropriate modules such as the router engine, 230, the router library 
240 and the randomization module 100. A check is made in step 406 as 
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to whether the determination regarding ordering the records is positive 
or negative. Additional information regarding this determination step is 
provided through the examples of exemplary embodiments discussed 
below in connection with Figs. 5A - 5D. If the determination in step 406 

5 is negative, then in step 408, the method provides the search results with 
the records in no order in response to the data inquiry. In other words, 
this branch of the method does not provide for any arrangement of the 
records into ordered records after receipt of the search results from the 
database search. The search results with the records in no order are 

10 provided generally to the appropriate destination as may be determined 
by the MRA 38 based on information associated with the search results. 
Thus, the search results with the records in no order may be provided to 
any of the delivery modules such as the TTS 220, the FAX 225, or other 
such module. This branch of the method then ends in step 410. 

15 Still referring to Fig. 4, it was noted above that a check is 

made in step 406 as to whether the determination regarding ordering the 
records is positive or negative. If the determination is positive, then in 
step 412, the records of the search results are arranged into ordered 
records. The term "ordered records" is used to describe the 

20 arrangement of the records of the search results into a set having a 
particular order for presentation of the records to the user in response to 
the data inquiry. In the exemplary system, a user is generally presented 
with the records of the data inquiry in serial fashion so that a particular 
record is heard, viewed or otherwise received first or before other 

25 records of the search results. Additional information regarding this 
arrangement step is provided through the examples of exemplary 
embodiments discussed below in connection with Figs. 5 A - 5D. After 
the records are arranged into ordered records in step 412, then in step 
414 the search results with the ordered records are provided in response 

30 to the data inquiry of the database. Generally, the search results are 
provided to the appropriate destination as may be determined by the 
MRA 38 based on information associated with the search results. Thus, 
the search results with ordered records may be provided to any of the 
delivery modules such as the TTS 220, the FAX 225, or other such 

35 module. This branch of the method then ends in step 410. 
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Alternative Methods Steps - Fig. 5 

As noted in the discussion of the exemplary method 
illustrated in Fig. 4, after the search results are received, a determination 
is made as to whether to arrange the records into ordered records. 

5 Generally stated, this determination may be an automatic positive 
determination to arrange records in all search results into ordered 
records. An automatic determination also may apply with respect to the 
type of ordered records into which the records are to be arranged. For 
example, the method may provide that the records of all received search 

10 results are to be arranged into ordered records, and that the records of 
all search results be arranged into a particular type of ordered records. 
On the other hand, the method may provide that records in all search 
results be arranged into ordered records, but further provide that the 
type of ordered records may depend on the particular search results. In 

15 other words, by this method, the type of ordered records may vary on a 
case by case basis. This determination of a type of ordered records may 
be based on characteristics of the particular set of search results. Thus, 
the method may provide that the records of all received search results be 
arranged into ordered records, but that the records of any particular set 

20 of search results be arranged into a type of ordered records based on 
characteristics associated with that particular set of search results. 

Alternatively, the determination as to whether to arrange the 
records of search results into ordered records may be a selectively 
positive determination in that such a determination is based on 

25 characteristics associated with the search results. This selectively positive 
determination may be made based on one or more of a variety of 
characteristics or factors of the search results such as the destination of 
the search results, an association of one or more of the records in the 
search results with a particular characteristic such as the association of a 

30 record with a client or other entity, status of one or more of the records 
in the search results as a preferred record, the frequency or number of 
times that a record or records have appeared in other search results, or a 
weighting factor assigned to one or more of the records in the search 
results. These characteristics or factors are discussed in greater detail 

35 below in connection with the exemplary methods described together with 
Figs. 5A - 5D. 
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Further, after a positive determination with respect to 
arranging the records of a particular set of search results has been made, 
then a further determination may be made as to the type of ordered 
records for the arrangement. This may be an automatic positive 
determination that follows on a selective positive determination with 
respect to arranging the records of a particular set of search results into 
ordered records. In other words, once it has been determined that a 
particular set of search results is to have ordered records based on some 
characteristic of the search results (rather than an automatic positive 
determination), then an automatic selection of the type of ordered 
records may be made. For example, assume that a particular set of 
search results is to have ordered records. The method may provide that 
in all cases that such a determination is positively made, the records then 
be arranged in a particular type of ordered records. 

The method also may provide that the determination as to 
the type of ordered records for a particular set of search results be made 
on a case by case basis, rather than be an automatic selection of type of 
ordered records. This determination as to the type of ordered records 
may be made based on a variety of characteristics or factors of the search 
results such as the characteristics and factors mentioned above in 
connection with the deteimination as to whether records of search results 
are to be arranged into ordered records. These characteristics or factors 
may include the destination of the search results, an association of one or 
more of the records in the search results with a particular characteristic 
such as the association of a record with a client or other entity, status of 
one or more of the records in the search results as a preferred record, 
the frequency or number of times that a record or records have appeared 
in other search results, or a weighting factor assigned to one or more of 
the records in the search results. 

Generally, the types of ordered records include: an 
alphabetical order of records, a preferred order of records based on the 
preferred status of one or more records over other records, a least 
frequent first order of records, a most frequency first order of records, 
a highest weighting factor first order, or a lowest weighting factor first 
or combinations thereof. 

Referring to Figs. 5A - 5D, exemplary embodiments of the 
present invention are described with respect to the determination steps as 
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to whether records of search results are to be ordered records, and if so, 
what type or combination of ordered records are to be arranged* 



Destination Determination - Fig. SA 

5 Fig, 5A is a flow diagram illustrating determination steps in 

the case of a determination made on the basis of the destination of a 
particular set of search results. The steps of this flow diagram, steps 502 
and 504, follow on from step 406 of Fig. 4 ("Order records?"). In step 
502, a destination determination is made for the search results, and then 

10 in step 504 the records are arranged in destination order. After step 
504, the method progresses to step 414 of Fig. 4 ("Provide search 
results*..")- I* 1 the preferred embodiment, these steps 502, 504 are 
executed in the MRA 38. Generally, the MRA 38, and in particular, the 
randomization module 100 and the router library 240 may include 

15 information and instructions for the arrangement of records in search 
results into ordered records based on the destination of the search results. 
The randomization module 100 may store information relating a possible 
destination for search results with instructions for the arrangement of 
records in the search results destined for this destination into ordered 

20 records that are arranged in a destination order. The destination order 
of records may be common to a plurality of destinations, or the 
destination order may be unique to a particular destination. 

As a further illustration of this destination determination 
example, assume that the search results are destined for a user who is 

25 awaiting a response via his or her telephone. In this case, the search 
results are to be routed from the MRA 38 to the TTS delivery module 
220. With the TTS delivery module 220 as the destination of the search 
results, it may be preferred that the records of the search results be 
delivered as ordered records rather than non-ordered ("no order") 

30 records. Thus, a check by the randomization module 100 results in the 
determination that the records of these search results be delivered as 
ordered records, and in particular, that the records be arranged in 
destination order. This destination order may require that the records be 
arranged in alphabetical or other order based on some characteristic of 

35 the individual records. Alternatively, this destination order may require 
that additional steps in the method be performed. For example, the 
records of the search results may need to be checked to determine 
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randomization module 100 keep track of the number of times that any 
particular record is included in search results. The randomization 
module 100 may store information relating a frequency characteristic of 
a record or search results with instructions for the arrangement of 
5 records in the search results associated with this characteristic into 
ordered records that are arranged in a least frequent first (LFF) or other 
order. The LFF order generally provides that the least frequent (LF) 
record is listed before other records in the search results. The LF 
record is a record of the search results that has been included in other 

10 search results less often than any other record of the search results; 

The LFF order of records may be common to a plurality of 
frequency characteristics, or the preferred order may be unique to a 
particular frequency characteristic. The LFF order may require that the 
records be arranged in an order whereby one or more records are 

15 ordered ahead of other records in the search results. This order may be 
determined based on the association or lack thereof of the frequency 
characteristic(s) with one or more of the records. Alternatively, this 
preferred order may require that additional steps in the method be 
performed. For example, the records of the search results may need to 

20 be checked to determine whether a record of the search results is an LF 
record. If so, then the records of the search results may be listed in an 
LFF order which includes listing an LF record or records before other 
records in the search results. 

Yet additional steps may be performed to order all of the 

25 records within a set of search results into ordered records based on the 
frequency characteristic of each record with respect to each other record 
in the search results. This frequency characteristic may be thought of as 
the number that is associated with a record and that reflects the number 
of times that the record has appeared in other search results. Thus, 

30 pursuant to these additional steps, the records may be arranged into 
ordered records based on the number of times that the records have 
appeared in other search results. The record with the lowest number or 
frequency characteristic may be listed first (or most advantageously), the 
record with the next lowest number or frequency characteristic may be 

35 listed second (or second most advantageously), etc. 

As a further illustration of this frequency determination 
example, assume that a particular client is a classified advertiser that has 
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paid a premium for the presentation of its information in an 
advantageous position in search results. In this case, the client definitely 
prefers that the records of the search results be delivered as ordered 
records rather than non-ordered records. Moreover, the client prefers 

5 that its records be delivered at least as often as other records and that the 
client's records hold an advantageous position in the search results. 
Many clients consider the first record position to be the most 
advantageous position in the order of records in search results. It is 
assumed that if the user is satisfied with the first record of the search 

10 results, then the user may not review the remainder of the records in the 
search results. Thus, the client may specify that its records be associated 
with a frequency characteristic that results in the client's records being 
arranged in advantageous positions in ordered records in search results. 

To further illustrate this frequency example, consider that a 

15 particular record may have been provided to a user as part of other 
search results that had been previously processed through the MRA 38. 
Because this record had been previously provided in search results, this 
previously provided record may be arranged in a less advantageous 
position or order in the search results under processing. By this 

20 arrangement, the available records in search results responsive to a 
particular data inquiry are rotated so that no particular record is 
provided with a repetitive advantageous position or order* 

It will be appreciated that the above described frequency 
determination ordered the records based on least frequency of 

25 appearance of records in other search results. This frequency 
determination may also be used in an analogous fashion, but based on 
most frequency of appearance of records in other search results. In 
other words, a type of ordered records may include records that are 
ordered such that the most frequently appearing record in other search 

30 results appears first in a particular set of search results, the second most 
frequently appearing record appears second, etc. A most frequent first 
(MFF) order may be useful in certain contexts such as the delivery of 
search results with the most popular records listed first or in preferred 
order over other records. In addition, it is explained above in 

35 connection with Fig. 5A that the LFF (or analogous) order methods may 
be used in connection with the destination order described above. 
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Weighting Factor Determination - Fig. 5D 
Fig, 5D is a flow diagram illustrating determination steps in 
the case of a determination made on the basis of characteristics or factors 
of records that are referred to herein as weighting factors. The steps of 

5 this flow diagram, steps 514 and 516, follow on from step 406 of Fig. 4 
("Order records?")* In step 514, a weighting factor determination is 
made for the search results, and then in step 516 the records are 
arranged in a highest weighting factor first (HWFF) order. After step 
516, the method progresses to step 414 of Fig. 4 ("Provide search 

10 results..."). Alternatively, rather than a weighting factor being as 
ascribed to or determined for each record of the search results, the 
weighting factor may be ascribed to or determined to only one or a 
selected number of records. 

Referring again to Fig. 5D, in the preferred embodiment, 

15 these steps 514, 516 are executed in the MRA 38. Generally, the MRA 
38, and in particular, the randomization module 100 and the router 
library 240 may include information and instructions for the 
arrangement of records in search results into ordered records based on 
the association of one or more of the records with a weighting factor or 

20 factors. These weighting factors may be based on any feature or element 
that may serve as the basis of the calculation and ascription of a 
weighting factor to records such as returned in search results. For 
example, a weighting factor may be ascribed to or determined for a 
particular record based on a ratio of the frequency or number of times 

25 that the record has appeared in other search results over a time period. 
The time period may be selected and resetted as appropriate. In this 
manner, the particular record may be better assured of appearing in an 
advantageous position in search results more often, on a regular basis, or 
at least in during a particular time period. 

30 To execute this weighting factor determination, the 

randomization module 100 may keep track of the weighting factor of any 
particular record. The randomization module 100 may store 
information relating a weighting factor of a record or search results with 
instructions for the arrangement of records in the search results 

35 associated with this characteristic into ordered records that are arranged 
in a highest weighting factor first (HWFF) or other order. The HWFF 
order generally provides that a highest weighting factor (HWF) record is 
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listed before other records in the search results. The HWF record is a 
record of the search results that has a higher weighting factor than any 
other record of the search results. 

The HWFF order of records may be common to a plurality 

5 of weighting factors, or the preferred order may be unique to a 
particular weighting factor. The HWFF order may require that the 
records be arranged in an order whereby one or more records is ordered 
ahead of or before other records in the search results. This order may 
be determined based on the association or lack thereof of a weighting 

10 factor with one or more of the records. Alternatively, this preferred 
order may require that additional steps in the method be performed. For 
example, the records of the search results may need to be checked to 
determine whether a record of the search results has a highest weighting 
factor. If so, then the records of the search results may be listed in an 

15 HWFF order which includes listing an HWF record or records before 
other records in the search results. 

Yet additional steps may be performed to order all of the 
records within a set of search results into ordered records based on the 
weighting factor of each record with respect to each other record in the 

20 search results. The record with the highest weighting factor may be 
listed first (or most advantageously), the record with the next highest 
weighting factor may be listed second (or second most advantageously), 
etc. 

As a further illustration of this weighting factor 
25 determination example, assume that a particular client is a classified 
advertiser that has paid a premium for the presentation of its information 
in an advantageous position in search results. In this case, the client 
definitely prefers that the records of the search results be delivered as 
ordered records rather than non-ordered records. Moreover, the client 
30 prefers that its records be delivered at least as often as other records and 
that the client's records hold an advantageous position in the search 
results. Thus, this client's records may be associated with a weighting 
factor that results in the client's records being arranged in advantageous 
positions in ordered records in search results. 
35 To further illustrate this example, consider that the records 

of a set of particular search results are each assigned a weighting factor. 
Such a weighting factor may be assigned to a record for any number of 
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reasons. For example, a client such as a classified advertiser may have 
paid a high premium for a high weighting factor assigned to one of its 
records. Another client may have paid a medium premium for a 
medium weighting factor assigned to one of its records. By these 

5 weighting factors, the record of the client with the high weighting factor 
may be arranged into a more advantageous position or order in the 
search results than the record of the client with the medium weighting 
factor. As a result, the user generally hears or views the record of the 
client that paid the high premium for the high weighting factor before 

10 the user hears or views the record of the client that paid the medium 
premium for the medium weighting factor. 

As another example, a particular weighting factor may be 
assigned to a particular record based on factors or characteristics 
associated with the data inquiry that initiated the search of the database 

15 and resulted in the search results. For example, a particular weighting 
factor may be assigned to a particular record based on the time of day of 
the data inquiry that resulted in the search results. To illustrate this 
example, assume that statistics demonstrate that short records in search 
results are preferred by users in response to data inquiries that are 

20 initiated in the evenings. Perhaps users have a shorter attention span in 
the evenings. Thus, a high weighting factor may be assigned to a short 
record in search results that are returned in response to a data inquiry 
that was initiated in the evening. Based on the highest weighting factor 
first order of records, the short record appears in an advantageous 

25 position in the search results. The user is satisfied because he or she was 
provided with search results that took into account the user's preferences 
for short records. Customer satisfaction is a high priority among service 
providers of information retrieval systems. 

The above described weighting factor determination ordered 

30 the records based on highest weighting factor of records in search 
results. This weighting factor determination also may be used in an 
analogous fashion but based on lowest weighting factor of records in 
search results. In other words, a type of ordered records may include 
records that are ordered such that the record having the lowest weighting 

35 factor in the search results appears first in a particular set of search 
results, the record having the second lowest weighting factor appears 
second, etc. A lowest weighting factor first (LWFF) order may be 
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useful in certain contexts. In addition, it is explained above in connection 
with Fig, 5 A that the HWFF order method may be used in connection 
with the destination order described above. 

5 Conclusion 

Advantageously, the present invention provides several 
different exemplary methods for arranging records into ordered records 
to be included in the search results provided in response to a data inquiry 
of a database. With this variety of methods for arranging records, the 

10 service provider benefits by retaining tactical and strategic input with 
respect to the provision of such search results in response data inquiries. 
By this invention, the service provider may benefit by being able to 
provide additional services or features with respect to information 
retrieval. These additional services or features may provide the service 

15 provider with competitive advantages over other service providers of 

uiiisimauiru. jui jjcu Liisiiiai , llic^C auiu uuiiai ociviuca ui icaiuic^ may 

serve to retain or attract clients as well as users to the service provider. 

The exemplary embodiments of the present invention have 
been described with reference to information retrieval systems, and in 

20 particular, with reference to a database of classified advertising 
information. Nonetheless, the principles of the present invention may be 
applied to any tasks or processes that retrieve elements of information 
such as records from whatever source and that transmit these elements of 
information to users or other entities. As part of these general retrieval 

25 and transmission processes, the principles of the present invention may 
be applied. Accordingly, the scope of the present invention should be 
defined only by the following claims rather than the foregoing 
description. 
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CLAIMS 

I claim: 

5 LA method for arranging records in search results to 

be provided in response to a data inquiry of a database, comprising the 
steps of: 

A, receiving the search results, the search results 

including records; 

10 B. making a destination determination for the 

search results; 

C. in response to the destination determination, 
arranging the records of the search results into a destination order in the 
search results based on the destination determination; and 
15 D. providing the records of the search results in 

the destination order in response to the data inquiry of the database. 

2. The method of Claim 1, wherein the destination order 
comprises an alphabetical order; 
20 wherein step C comprises arranging the records of the 

search results in the alphabetical order; and 

wherein step D comprises providing the records of the 
search results in the alphabetical order. 

25 3. The method of Claim 1, wherein the destination order 

comprises a preferred order of listing a preferred record before other 

records in the search results; 

wherein step C comprises, in response to the 

destination determination, 
30 a. determining whether a record of the 

search results is the preferred record, and 

b. if the record is the preferred record, then 

arranging the records of the search results in the preferred order in the 

search results; and 

35 wherein step D comprises providing the records of the 

search results in the preferred order. 



WO 99/12106 



PCT/US98/16866 



36 

4. The method of Claim 1, wherein the destination order 
comprises a least frequent first (LFF) order, the LFF order providing 
that a least frequent (LF) record is listed before other records in the 
search results, the LF record being one of the records of the search 
results that has been included in other search results less often than any 
other of the records of the search results; 

wherein step C comprises, in response to the 
destination determination, determining the LF record of the search 
results, and then arranging the records of the search results into the LFF 
order; and 

wherein step D comprises providing the records of the 
search results in the LFF order in response to the data inquiry of the 
database. 

5. The method of Claim 1, wherein the destination order 
comprises a highest weighting factor first (HWhr) order, the KWFF 
order providing that a highest weighting factor (HWF) record is listed 
before other records in the search results, the HWF record being one of 
the records of the search results that has a higher weighting factor than 
any other record of the search results; 

wherein step C comprises, in response to the 
destination determination, determining the HWF record of the search 
results, and then arranging the records of the search results into the 
HWFF order; and 

wherein step D comprises providing the records of the 
search results in the HWFF order in response to the data inquiry of the 
database. 
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6* A method for arranging records in search results to 
be provided in response to a data inquiry of a database, comprising the 
steps of: 

A. receiving the search results, the search results 

including records; 

B. making a marketing determination for the 
search results that the records of the search results be provided in a 
preferred order, the preferred order providing that a preferred record is 
listed before other records in the search results; 

C. in response to the marketing determination, 
determining whether a record of the search 

results is the preferred record, and 

if the record is the preferred record, then 
arranging the records of the search results into the preferred order in the 
search results; and 

D. providing the records of the search results in 
the preferred order in response to the data inquiry of the database. 
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7. A computer-readable medium on which is stored a 
computer program for arranging records in search results to be provided 
in response to a data inquiry of a database, the computer program 
comprising instructions, which when executed by a computer, perform 
the steps of: 

A. receiving the search results including records; 

B. making a determination regarding an order of 
the records in the search results wherein the determination may be based 
on at least one of the following: the destination of the search results, the 
preferred status of certain records over other records, a marketing 
determination with respect to the records, a frequency determination 
with respect to the number of times that a record may have already been 
provided in response to data inquiries, or a weighting factor, 

C. in response to the determination, arranging the 
records of the search results as ordered records; and 

D. providing the ordered records of the search 
result including the ordered records in response to the data inquiry of the 
database. 

8. The computer-readable medium of Claim 7, wherein 
the ordered records may be the records arranged into at least one of the 
following orders: an alphabetical order, a preferred order based on the 
preferred status of a record over the other records, a least frequent first 
order, or a highest weighting factor first order. 
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AMENDED CLAIMS 

[received by the International Bureau on 22 June 1999 (22.06.99); 
original claims 1-8 replaced by amended claims 1-20 (7 pages)] 



1. A method for arranging records in search results to 
5 be provided in response to a data inquiry of a database, comprising the 

steps of: 

A. receiving the search results, the search 
results including records; 

B. making a destination determination for the 

10 search results; 

C. in response to the destination determination, 
arranging the records of the search results into a destination order in 
the search results based on the destination determination; and 

D. providing the records of the search results in 
15 the destination order in response to the data inquiry of the database. 

2. The method of Claim 1, wherein the destination 
order comprises a preferred order of listing a preferred record before 
other records in the search results; 

20 wherein step C comprises, in response to the 

destination determination, 

a. determining whether a record of the 
search results is the preferred record, and 

b. if the record is the preferred record, 
25 then arranging the records of the search results in the preferred order 

in the search results; and 

wherein step D comprises providing the records of 
the search results in the preferred order. 
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3. The method of Claim 1, wherein the destination 
order comprises a least frequent first <LFF) order, the LFF order 
providing that a least frequent (LF) record is listed before other records 
in the search results, the LF record being one of the records of the 
5 search results that has been included in order search results less often 

than any other of the records of the search results; 

wherein step C comprises, in response to the 
destination determination, determining the LF record of the search 
results, and then arranging the records of the search results into the 
10 LFF order; and 

wherein step D comprises providing the records of 
the search results in the LFF order in response to the data inquiry of the 
database. 

25 4. The method of Claim 1, wherein the destination 

order comprises a highest weighting factor first (HWFF) order, the 
HWFF order providing that a highest weighting factor (HWF) record is 
listed before other records in the search results, the HWF record being 
one of the records of the search results that has a higher weighting 

20 factor than any other record of the search results; 

wherein step C comprises, in response to the 
destination determination, determining the FIWF record of the search 
results, and then arranging the records of the search results into the 
HWFF order; and 

25 wherein step D comprises providing the records of 

the search results in the HWFF order in response to the data inquiry of 
the database 
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5. A method for arranging records in search results to 
be provided in response to a data inquiry of a database, comprising the 
steps of: 

A. receiving the search results, the search 
5 results including records; 

B« making a marketing determination for the 
search results that the records of the search results be provided in a 
preferred order, the preferred order providing that a preferred record is 
listed before other records in the search results; 
10 C. in response to the marketing determination, 

determining whether a record of the search 
results is the preferred record, and 

if the record is the preferred record, then 
arranging the records of the search results into the preferred order in 
15 the search results; and 

D. providing the records of the search results in 
the preferred order in response to the data inquiry of the database. 
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6. A computer-readable medium on which is stored a 
computer program for arranging records in search results to be 
provided in response to a data inquiry of a database, the computer 
program comprising instructions, which when executed by a computer, 

5 perform the steps of: 

A. receiving the search results including 

records; 

B. making a determination regarding an order 
of the records in the search results wherein the determination may be 

10 based on at least one of the following: the destination of the search 

results, the preferred status of certain records over other records, a 
marketing determination with respect to the records, a frequency 
determination with respect to the number of times that a record may 
have already been provided in response to data inquiries, or a 

15 weighting factor; 

C. in response to the determination, arranging 
the records of the search results as ordered records; and 

D. providing the ordered records of the search 
result including the ordered records in response to the data inquiry of 

20 the database. 

7. The computer-readable medium of Claim 6, 
wherein the ordered records may be the records arranged into at least 
one of the following orders: a preferred order based on the preferred 

25 status of a record over the other records, a least frequent first order, or a 

highest weighting factor first order. 
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8. A method for arranging results of a search of a 
database, comprising the steps of: 

receiving a data inquiry for the database; 
5 based on the data inquiry, obtaining search results 

comprising a plurality of records; 

determining whether to order the records into 
ordered records in response to identifying an ordering characteristic 
associated with the search results; 
10 arranging the records into the ordered records based 

on the ordering characteristic; and 

providing the ordered records as a response to the 

data inquiry. 

15 9. The method of Claim 8 wherein the step of 

determining whether to order the records further comprises 
identifying a destination of the search results. 

10. The method of Claim 8 wherein the step of 
20 determining whether to order the records further comprises 

identifying a preferred status characteristic associated with the search 
results. 

11. The method of Claim 8, wherein the step of 
25 determining whether to order the records further comprises the step of 

conducting a marketing determination based on the search results. 
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12. The method of Claim 11, wherein the step of 
conducting a marketing determination based on the search results further 
comprises the step of determining whether at least one of the records is 
associated with a predefined entity. 

5 

13. The method of Claim 8, wherein the step of 
determining whether to order the records further comprises determining 
the frequency that at least one of the records of the search results was 
obtained in response to previous data inquiries. 

10 

14. The method of Claim 8 wherein the step of 
determining whether to order the records further comprises identifying a 
weighting characteristic associated with the records of the search results. 

15 15. The method of Claim 8, wherein the step of arranging 

the records comprises arranging the records based on a preferred status of 
certain records in comparison to the status of the remaining records. 

16. The method of Claim 8, wherein the step of arranging 
20 the records comprises arranging the records in a least frequent first order. 

17. The method of Claim 8, wherein the step of arranging 
the records comprises arranging the records in a most frequent first order. 

25 18. The method of Claim 8, wherein the step of arranging 

records comprises arranging records in a highest weighting factor first 
order. 
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19. The method of Claim 8, wherein the step of 
determining whether to order the records comprises receiving a user- 
command requesting the ordering of the records. 

5 20. The method of Claim 8, wherein the step of arranging 

the records comprises arranging the records based on a user-command 
specifying the ordering characteristic. 
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